<template>
  <a-card :bordered="false">

<template>
 
  <a-descriptions title="开票记录" layout="vertical">
    <a-descriptions-item label="名称">
      <b> <span size="8">{{this.companyName}} </span></b>
    </a-descriptions-item>
    <a-descriptions-item label="用户编号" style="float:left">
      {{this.businesslicense}}
    </a-descriptions-item>
    <a-descriptions-item label="联系电话">
     {{this.phone}}
    </a-descriptions-item>
    <a-descriptions-item label="已开票金额" span="2">
     {{this.yiInvoicemoney}}元
    </a-descriptions-item>
    <a-descriptions-item label="未开票金额">
     {{this.weiInvoicemoney}}
    </a-descriptions-item>
  </a-descriptions>
   <a-button @click="see_addInvoice()" type="primary" icon="plus" style="color: #F9D532;width: 200px;height: 36px;background: #333333;border-style: none;">新增开票记录</a-button>
</template>
<hr>
    <!-- 查询区域 -->
    <div class="table-page-search-wrapper">
      <a-form layout="inline" @keyup.enter.native="searchQuery">
        <a-row :gutter="24">

          <a-col :xl="6" :lg="7" :md="8" :sm="24">
           打款记录
          </a-col>
     
       
          <span style="float: left;overflow: hidden;" class="table-page-search-submitButtons">
            
          </span>
        </a-row>
      </a-form>
    </div>

    <!-- table区域-begin -->
    <div>
      <a-table
        ref="table"
        size="middle"
        bordered
        rowKey="id"
        :columns="columns"
        :dataSource="dataSource"
        :pagination="ipagination"
        :loading="loading"
        :rowSelection="{selectedRowKeys: selectedRowKeys, onChange: onSelectChange}"
        @change="handleTableChange">

        <div slot="filterDropdown">
          <a-card>
            <a-checkbox-group @change="onColSettingsChange" v-model="settingColumns" :defaultValue="settingColumns">
              <a-row>
                <template v-for="(item,index) in defColumns">
                  <template v-if="item.key!='rowIndex'&& item.dataIndex!='action'">
                    <a-col :span="12"><a-checkbox :value="item.dataIndex">{{ item.title }}</a-checkbox></a-col>
                  </template>
                </template>
              </a-row>
            </a-checkbox-group>
          </a-card>
        </div>
        <a-icon slot="filterIcon" type='setting' :style="{ fontSize:'16px',color:  '#108ee9' }" />


  <span slot="action" slot-scope="text, record">
          <a @click="see_pingzheng(record.voucher)">查看凭证</a>&nbsp;

          <a-divider type="vertical"/>
     
        </span>

      </a-table>
    </div>
    <!-- table区域-end -->

    <!-- 表单区域 -->
    <jeecgDemo-modal ref="modalForm" @ok="modalFormOk"></jeecgDemo-modal>

    <!-- 一对多表单区域 -->
    <JeecgDemoTabsModal ref="jeecgDemoTabsModal" @ok="modalFormOk"></JeecgDemoTabsModal>
 <pingzheng ref="pingzhenglook" @ok="modalFormOk"></pingzheng>
<addInvoice ref="seeaddInvoice" @aaa="shuaxinyemian"></addInvoice>
  </a-card>
</template>

<script>

  import JSuperQuery from '@/components/jeecg/JSuperQuery.vue';
  import { deleteAction, getAction, putAction, postAction, downFile, getFileAccessHttpUrl } from '@/api/manage'
  import JInput from '@/components/jeecg/JInput.vue';
  import {initDictOptions, filterDictText,filterDictTextByCache} from '@/components/dict/JDictSelectUtil'
  import { JeecgListMixin } from '@/mixins/JeecgListMixin'
  import Vue from 'vue'
  import { filterObj } from '@/utils/util';
  import addInvoice from './modules/addInvoice';
    import pingzheng from './modules/pingzheng';
  //高级查询modal需要参数
  const superQueryFieldList=[
    {
      type: "string",
      value: "name",
      text: "用户名"
    }, {
      type: "int",
      value: "age",
      text: "年龄"
    }, {
      type: "date",
      value: "birthday",
      text: "生日"
    }
  ]
  export default {
    name: "SupplierInvoice",
    mixins:[JeecgListMixin],
    components: {
     addInvoice,
      JSuperQuery,
   pingzheng,
      JInput
    },
    data() {
      return {

        yiInvoicemoney:'',
        weiInvoicemoney:'',
       companyName:'',
       businesslicense:'',
        phone:'',
        ordernums:'',
        duizhangmoney:'',
        description: '单表示例列表',
        //字典数组缓存
        sexDictOptions: [],
        importExcelUrl:`${window._CONFIG['domianURL']}/test/jeecgDemo/importExcel`,
        //表头
        columns:[],
        //列设置
        settingColumns:[],
        //列定义
        defColumns: [
          {
            title: '序号',
            dataIndex: '',
            key: 'rowIndex',
            width: 60,
            align: "center",
            customRender: function (t, r, index) {
              return parseInt(index) + 1;
            }
          },
        
          {
            title: '发票编号',
            align: "center",
            dataIndex: 'invoiceNumber'
          },
          {
            title: '开票时间',
            align: "center",
            dataIndex: 'createTime'
          },    
         {
            title: '结算金额',
            align: "center",
            dataIndex: 'invoiceAmount'
           
          },
					{
					  title: '状态',
					  align: "center",
					  dataIndex: 'status',
					  customRender: (status) => {
					    //字典值替换通用方法
					    if(status==0)
					    return "未开票";
					    else  if(status==1)
					    return "已开票";
					  }
					},
          {
            title: '操作',
            dataIndex: 'action',
            align: "center",
            scopedSlots: {
              filterDropdown: 'filterDropdown',
              filterIcon: 'filterIcon',
              customRender: 'action'},
          }
        ],
        url: {
          list: "/Supplier/SupplierkaipiaoList?id="+this.$route.query.id,
          duizhangdetail:"/Supplier/duizhangdetail"
        },
        fieldList:superQueryFieldList
      }
    },
    methods: {
        see_pingzheng: function (img) {
      this.$refs.pingzhenglook.edit(img);
      this.$refs.pingzhenglook.title = "查看凭证";
      this.$refs.pingzhenglook.disableSubmit = false;
      },
see_addInvoice: function () {
      this.$refs.seeaddInvoice.edit(this.$route.query.id,1);
      this.$refs.seeaddInvoice.title = "新增开票记录";
      this.$refs.seeaddInvoice.disableSubmit = false;
      },
	  shuaxinyemian(){
		  this.getduizhangdetail();
		  this.searchQuery();
	  },
      getduizhangdetail(){

       getAction(this.url.duizhangdetail,{"id":this.$route.query.id}).then((res)=>{
     if(res.success){
              this.companyName=res.result.companyName,
               this.businesslicense=res.result.businesslicense,
            this.phone=res.result.phone,
              this.ordernums=res.result.ordernums,
             this.duizhangmoney=res.result.duizhangmoney,
               this.yiInvoicemoney=res.result.yiInvoicemoney,
                  this.weiInvoicemoney=res.result.weiInvoicemoney
              }else{
                this.$message.warning(res.message);
              }

          })
              
      },
      getQueryParams(){
        //高级查询器
        let sqp = {}
        if(this.superQueryParams){
          sqp['superQueryParams']=encodeURI(this.superQueryParams)
          sqp['superQueryMatchType'] = this.superQueryMatchType
        }
        var param = Object.assign(sqp, this.queryParam, this.isorter ,this.filters);

        param.field = this.getQueryField();
        param.pageNo = this.ipagination.current;
        param.pageSize = this.ipagination.pageSize;
        delete param.birthdayRange; //范围参数不传递后台
        return filterObj(param);
      },
      initDictConfig() {
        console.log("--我才是真的方法!--")
        //初始化字典 - 性别
        initDictOptions('sex').then((res) => {
          if (res.success) {
            this.sexDictOptions = res.result;
          }
        });
      },
      onetomany: function () {
        this.$refs.jeecgDemoTabsModal.add();
        this.$refs.jeecgDemoTabsModal.title = "编辑";
      },
      
      onBirthdayChange: function (value, dateString) {
        console.log(dateString[0],dateString[1]);
        this.queryParam.birthday_begin=dateString[0];
        this.queryParam.birthday_end=dateString[1];
      },
      //列设置更改事件
      onColSettingsChange (checkedValues) {
        var key = this.$route.name+":colsettings";
        Vue.ls.set(key, checkedValues, 7 * 24 * 60 * 60 * 1000)
        this.settingColumns = checkedValues;
        const cols = this.defColumns.filter(item => {
          if(item.key =='rowIndex'|| item.dataIndex=='action'){
            return true
          }
          if (this.settingColumns.includes(item.dataIndex)) {
            return true
          }
          return false
        })
        this.columns =  cols;
      },
      initColumns(){
        //权限过滤（列权限控制时打开，修改第二个参数为授权码前缀）
        //this.defColumns = colAuthFilter(this.defColumns,'testdemo:');

        var key = this.$route.name+":colsettings";
        let colSettings= Vue.ls.get(key);
        if(colSettings==null||colSettings==undefined){
          let allSettingColumns = [];
          this.defColumns.forEach(function (item,i,array ) {
            allSettingColumns.push(item.dataIndex);
          })
          this.settingColumns = allSettingColumns;
          this.columns = this.defColumns;
        }else{
          this.settingColumns = colSettings;
          const cols = this.defColumns.filter(item => {
            if(item.key =='rowIndex'|| item.dataIndex=='action'){
              return true;
            }
            if (colSettings.includes(item.dataIndex)) {
              return true;
            }
            return false;
          })
          this.columns =  cols;
        }
      }
    },
    created() {
      this.initColumns();
       this.getduizhangdetail();
      
    },
  }
</script>
<style scoped>
  @import '~@assets/less/common.less';
</style>